/* When resizing viewport we allow this extra
size to avoid constantly reallocating when resizing */
-#define ALLOW_SMALLER_SIZE 32
-#define ALLOW_LARGER_SIZE 32
+#define ALLOW_SMALLER_SIZE_FACTOR 0.5
+#define ALLOW_LARGER_SIZE_FACTOR 1.25
struct _GtkPixelCache {
cairo_surface_t *surface;
/* If current surface can't fit view_rect or is too large, kill it */
if (cache->surface != NULL &&
(cairo_surface_get_content (cache->surface) != content ||
- cache->surface_w < MAX(view_rect->width, surface_w - ALLOW_SMALLER_SIZE) ||
- cache->surface_w > surface_w + ALLOW_LARGER_SIZE ||
- cache->surface_h < MAX(view_rect->height, surface_h - ALLOW_SMALLER_SIZE) ||
- cache->surface_h > surface_h + ALLOW_LARGER_SIZE ||
+ cache->surface_w < MAX(view_rect->width, surface_w * ALLOW_SMALLER_SIZE_FACTOR) ||
+ cache->surface_w > surface_w * ALLOW_LARGER_SIZE_FACTOR ||
+ cache->surface_h < MAX(view_rect->height, surface_h * ALLOW_SMALLER_SIZE_FACTOR) ||
+ cache->surface_h > surface_h * ALLOW_LARGER_SIZE_FACTOR ||
cache->surface_scale != gdk_window_get_scale_factor (window)))
{
cairo_surface_destroy (cache->surface);